﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;
namespace ZX.TR.Library
{
    /// <summary>
    /// 
    /// </summary>
    [Serializable]
    [Table(Name = "V_Trcustomer")]
    [ZX.DBModule.Table("V_Trcustomer", "TrCustomerId")]
    public class V_TrCustomer : ZX.DBModule.BaseEntity
    {
        #region Business Methods 业务方法

        /// <summary>
        /// 客户ID
        /// </summary>
        private static PropertyInfo<Guid> TrCustomerIdroperty = RegisterProperty(typeof(V_TrCustomer), new PropertyInfo<Guid>("TrCustomerId"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid TrCustomerId
        {
            get { return GetProperty(TrCustomerIdroperty); }
            set { SetProperty(TrCustomerIdroperty, value); }
        }
        /// <summary>
        /// 客户编码
        /// </summary>
        private static PropertyInfo<string> CustomerCodeProperty = RegisterProperty(typeof(V_TrCustomer), new PropertyInfo<string>("CustomerCode"));
        [DataObjectField(true, true)]
        [Column, PK]
        public string CustomerCode
        {
            get { return GetProperty(CustomerCodeProperty); }
            set { SetProperty(CustomerCodeProperty, value); }
        }

        /// <summary>
        /// 客户名称
        /// </summary>
        private static PropertyInfo<string> CustomerNameProperty = RegisterProperty(typeof(V_TrCustomer), new PropertyInfo<string>("CustomerName"));
        [Column]
        public string CustomerName
        {
            get { return GetProperty(CustomerNameProperty); }
            set { SetProperty(CustomerNameProperty, value); }
        }
        /// <summary>
        /// 部门名称
        /// </summary>
        private static PropertyInfo<string> DeptnameProperty = RegisterProperty(typeof(V_TrCustomer), new PropertyInfo<string>("deptname"));
        [Column]
        public string Deptname
        {
            get { return GetProperty(DeptnameProperty); }
            set { SetProperty(DeptnameProperty, value); }
        }
        #endregion

        #region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid TrCustomerId)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
            using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("TrCustomerId").Equal(TrCustomerId);
                var data = db.Select<V_TrCustomer>(q)[0];
                LoadProperty(TrCustomerIdroperty, data.TrCustomerId);
                LoadProperty(CustomerCodeProperty , data.CustomerCode);
                LoadProperty(CustomerNameProperty, data.CustomerName);
                LoadProperty(DeptnameProperty, data.Deptname);
            }
        }
        #endregion
    }
}
